草庐IT

Java BufferedImage 内存消耗

全部标签

C++ 在不激活构造函数的情况下分配内存

我正在从一个文件中读取值,我将在读取它们时将其存储在内存中。我在这里读到,在C++中处理内存位置的正确方法是始终使用new/delete,但是如果我这样做:DataType*foo=newDataType[sizeof(DataType)*numDataTypes];然后将为每个创建的实例调用默认构造函数,我不希望这样。我打算这样做:DataType*foo;char*tempBuffer=newchar[sizeof(DataType)*numDataTypes];foo=(DataType*)tempBuffer;但我认为这会是某种类型不安全的东西。那我该怎么办呢?现在在研究这个问

c++ - new 未调用,但已分配内存

我写了一个简单的Trie执行。这是源代码:#include#includetypedefunsignedintuint;classTrie{public:classNode{public:Node(constchar&_value);~Node();charget_value()const;voidset_marker(constuint&_marker);uintget_marker()const;booladd_child(Node*_child);Node*get_child(constchar&_value)const;voidclear();private:charm_val

c++ - 递归函数的内存分配

调用递归函数时内存是如何分配的?一个函数有它自己分配的内存。当它被调用时,参数(不是引用传递的参数)和变量获得内存。那么,当从函数体内再次调用该函数时,如何将内存分配给第二次调用的变量和参数? 最佳答案 递归函数与任何其他函数没有什么不同——自动局部变量通过将堆栈指针推进到足够远以说明它们的大小总和(加上对齐所需的任何填充)而作为单个block分配。每个递归调用都会以这种方式压入一个新的堆栈帧,然后在返回时将其弹出。如果递归未能达到基本情况,堆栈将迅速耗尽,导致同名的StackOverflow崩溃。

c++ - 堆栈内存如何工作或函数变量如何在堆栈上分配和访问

当我在这个page上读到Stack和Heap的例子时,我有一个问题,如果像页面上给出的示例一样,一个函数将其所有局部变量放在堆栈上,堆栈实际上是否访问不同的变量?因为堆栈通常只能访问顶部,所以它只能访问函数的一个变量。这是否意味着函数的变量存储在堆栈上的结构中? 最佳答案 堆栈指针,顾名思义,是一个和其他指针一样的指针,它指向普通的标准内存。要访问堆栈的任何区域,您只需向指针添加一个偏移量。如果你从C指针的角度来考虑它,你就有堆栈指针char*stack_pointer=some_memory;这个指针然后可以用作普通指针,包括添加

c++ - unique_ptr 释放会导致内存泄漏吗?

我对unique_ptr.release()感到困惑。我的目标是投出一个unique_ptr基类到派生类的unique_ptr。所以我找到了这个question答案是Derived*tmp=dynamic_cast(basePointer.get());std::unique_ptrderivedPointer;if(tmp!=nullptr){basePointer.release();derivedPointer.reset(tmp);}或std::unique_ptrderivedPointer(static_cast(basePointer.release()));然后我想知道

c++ - 释放内存的重要性?

这个问题在这里已经有了答案:关闭13年前。PossibleDuplicate:WhatREALLYhappenswhenyoudon’tfreeaftermalloc?在C/C++中结束程序时,您必须通过释放指针来清理。如果你不释放内存会发生什么,比如你有一个指向int的指针并且在程序结束时没有删除它?内存是否还在使用,只能重启才能释放,还是程序结束时自动释放?在最后一种情况下,如果操作系统为您做了,为什么要释放它?

c++ - 动态内存分配

与数组中元素的普通分配相比,使用动态内存分配创建数组有什么优势? 最佳答案 您不必事先知道数组的大小,也不必为大型数组过度分配内存。这使您的程序可以更高效地使用内存。 关于c++-动态内存分配,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/2311108/

c++ - 当 C++ 程序结束时,指针是否从内存中释放?

这是一个初学者问题,但我用C#学习编程,现在我正在转向C++,现在我正在使用指针,我知道当我完成它们时我必须从内存中释放它们,但是当程序已关闭,它们是从内存中删除还是留在那儿? 最佳答案 当您的程序结束时,它使用的所有内存(无论是否动态分配)都会返回给操作系统。不管它是C程序、C++程序、C#程序还是您可能正在编写的任何其他类型的程序。现在,仅仅因为操作系统会回收内存并不意味着您可以对内存管理漫不经心。当您的程序运行时,您应该设法释放您已完成的所有内存。不这样做会导致“内存泄漏”,而这些肯定会影响您的程序及其运行的系统,至少在您的程

c++ - 为什么 bool 看起来占用的内存和 int 一样多? C++

当我在devcpp运行这个程序时,任务管理器说它大约有79MB。使用gnuc++4.7的Codeforces说它是79112KB#includeconstintN=10010,K=1010;structTPos{intcharge;boolex;TPos(){charge=1但是当exparametr被注释时:#includeconstintN=10010,K=1010;structTPos{intcharge;//boolex;TPos(){charge=1只有39536KB。我认为boolean值应该使用一个字节。为什么它的大小增加了一倍? 最佳答案

c++ - 对象的内存分配

当我们在c++中实例化一个变量,如函数中的intx(即x是一个局部变量)时,它被分配在进程的堆栈顶部。但是如果我们执行int*x=newint,空间将在堆中提供。所以,我的问题是:不同类(c++提供的类或用户定义的类)的对象呢?他们的对象在哪里实例化?例如:让Employee是一个类,我们声明Employeeemp;。emp在堆栈或堆中的何处给定空间->?如果声明inta[4]在一个函数内,a的所有四个单元是否都在堆栈上获得空间? 最佳答案 所有局部变量,无论是来自类的内置类型,还是数组,都在堆栈上。所有动态分配都在堆上。当然,局部